package com.shop.mapper;

import com.shop.entity.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * @author XCH
 * @date 2025 - 05 - 19
 */
@Mapper
public interface UserMapper {
    /**
     * 查询所有用户
     * @param page
     * @param limit
     * @return
     */
    List<User> listUser(@Param("page")int page, @Param("limit") int limit);

    /**
     * 添加用户
     * @param user
     */
    void addUser(User user);

    /**
     * 删除用户
     * @param id
     */
    void deleteUser(@Param("id") Integer id);

    /**
     * 修改用户
     * @param user
     */
    void updateUser(User user);

    /**
     * 用户登录
     * @param username
     * @param password
     * @return
     */
    User userLogin(@Param("username") String username,@Param("password")  String password);

    /**
     * 根据ID查询用户
     * @param id
     */
    User SelectByUserId (@Param("id") Integer id);

    User selectByEmail(String email);

    /**
     * 查询用户总数
     * @return
     */
    int  countUser();

    /**
     * 根据用户名查询用户
     * @param username
     * @return
     */
    User selectByUsername(@Param("username")String username);

    void updateUserPassword(@Param("id")Integer id, @Param("password") String password);

    void updateUserPhone(@Param("id")Integer id, @Param("phone") String phone);

    void updateImage(@Param("id")Integer id, @Param("image") String image);

    void updateNickname(@Param("id")Integer id, @Param("nickname") String nickname);

    void updateEmail(@Param("id")Integer id, @Param("email") String email);

    void updateSex(@Param("id")Integer id, @Param("sex") String sex);

    void updateUsername(@Param("id")Integer id, @ Param("username") String username);
}
